<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryForm" :inline="true" label-width="68px">

      <el-form-item label="日期">
        <el-date-picker
          v-model="queryParams.accessDate"
          size="small"
          style="width: 140px"
          value-format="yyyy-MM-dd"
        />
      </el-form-item>
      <el-form-item label="时间段" prop="timeSlot">
        <el-select
          v-model="queryParams.timeSlot"
          placeholder="时间段"
          clearable
          size="small"
          style="width: 180px">
          <el-option
            v-for="dict in timeSlotOptions"
            :key="dict.dictValue"
            :label="dict.dictLabel"
            :value="dict.dictValue"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="所属部门" prop="classDeptId">
        <el-select
          v-model="queryParams.classDeptId"
          placeholder="班级所属部门"
          clearable
          size="small"
          style="width: 180px">
          <el-option
            v-for="dict in classDeptOptions"
            :key="dict.dictValue"
            :label="dict.dictLabel"
            :value="dict.dictValue"
          />
        </el-select>
      </el-form-item>

      <el-form-item>
        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
          type="warning"
          icon="el-icon-download"
          size="mini"
          @click="handleExport"
          v-hasPermi="['report:exportclassattencesta:attencelist']"
        >导出</el-button>
      </el-col>
    </el-row>



    <el-table v-loading="loading" :data="CAttenceStaList">
      <el-table-column label="日期" align="center" prop="accessDate" :show-overflow-tooltip="true" />
      <el-table-column label="时间段" align="center" prop="timeSlot" :show-overflow-tooltip="true" />
      <el-table-column label="部门" align="center" prop="classDeptName" :show-overflow-tooltip="true" />
      <el-table-column label="班级" align="center" prop="className" :show-overflow-tooltip="true" />
      <el-table-column label="班级总人数" align="center" prop="totalCount" :show-overflow-tooltip="true" />
      <el-table-column label="正常出勤人数" align="center" prop="normalCount" :show-overflow-tooltip="true" />
      <el-table-column label="迟到人数" align="center" prop="lateCount" :show-overflow-tooltip="true" />
      <el-table-column label="请假人数" align="center" prop="leaveCount" :show-overflow-tooltip="true" />

    </el-table>


    <pagination
      v-show="total>0"
      :total="total"
      :page.sync="queryParams.pageNum"
      :limit.sync="queryParams.pageSize"
      @pagination="getList"
    />

  </div>
</template>



<script>
  import { listClassAttenceStatistics,exportClassAttenceSta} from "@/api/report/classattencestatistics";
  export default {
    name: "ClassAttenceSta",
    data(){
      return{
        // 遮罩层
        loading: true,
        // 选中数组
        ids: [],
        // 非单个禁用
        single: true,
        // 非多个禁用
        multiple: true,
        // 总条数
        total: 0,
        CAttenceStaList: [],
        classDeptOptions: [],
        timeSlotOptions: [],
        // 弹出层标题
        title: "",
        // 是否显示弹出层
        open: false,
        // 查询参数
        queryParams: {
          pageNum: 1,
          pageSize: 10,
          accessDate: undefined,
          timeSlot:undefined,
          classDeptId:undefined
        },
      }
    },
    components:{
    },
    created() {
      this.getList();
      this.getDicts("class_dept").then(response => {
        this.classDeptOptions = response.data;
      });
      this.getDicts("time_slot").then(response => {
        this.timeSlotOptions = response.data;
      });
    },
    methods: {
      /** 查询任务量列表 */
      getList() {
        this.loading = true;
        listClassAttenceStatistics(this.queryParams).then(response => {
            this.CAttenceStaList= response.data.list;
            this.total = response.data.total;
            this.loading = false;
        });
      },
      // 取消按钮
      cancel() {
        this.open = false;
        this.reset();
      },
      /** 搜索按钮操作 */
      handleQuery() {
        this.queryParams.pageNum = 1;
        this.getList();
      },
      /** 重置按钮操作 */
      resetQuery() {
        this.dateRange = [];
        this.resetForm("queryForm");
        this.handleQuery();
      },
      /** 导出按钮操作 */
      handleExport() {
        const queryParams = this.queryParams;
        this.$confirm('是否确认导出所有班级考勤统计数据项?', "警告", {
            confirmButtonText: "确定",
            cancelButtonText: "取消",
            type: "warning"
          }).then(function() {
            return exportClassAttenceSta(queryParams);
          }).then(response => {
            this.fileDownload(response.data, "班级考勤统计管理.xlsx");
          }).catch(function() {});
      },
    }
  }
</script>
